110- 



ENTRY OF FILE NUMBER AND/OR OTHER 
IDENTIFICATION INFO, AND AMOUNT FOR 
CHECK. INTO REMOTE WORKSTATION 
AT LAW FIRM 



112-f 



114 
i 



CHECK PRINTED ON WORKSTATION 
PRINTER, AND MAILED TO PATENT 
AND TRADEMARK OFFICE 



PTO RECEIVES 
CHECK ANO CASHES 
AGAINST BANK ACCOUNT 



120 



CENTRAL OFFICE 
DEPOSITS MONEY 
IN ACCOUNT OR 
OTHERWISE INSURE 
ADEQUATE FUNDS 
PRESENT 



126 
i 




INFORMATION REGARDING 
CHECKS PRINTED UPLOADED 
TO CENTRAL OFFICE 
BY REMOTE WORKSTATION 



122- 



T 



ELECTRONIC INVOICE GENERATED 
AND TRANSMITTED TO LAW FIRM 
ACCOUNTING SYSTEM; PAPER 
INVOICE ALSO GENERATED 
BY WORKSTATION 



8ANK SENDS TO 
CENTRAL OFFICE 

MONTHLY STATEMENT 
OF TRANSACTIONS 

TO CENTRAL OFFICE 



128 
__S 




CENTRAL OFFICE RECONCILES 

MONTHLY STATEMENT WITH 
INFORMATION UPLOADED BY WS 



FIG. 1A 
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CENTRAL OFFICE 
SENDS BILL TO 
LAW FIRM FOR 
MONEY LOANED 
TO CLIENTS 



136 
_i 



BILL DUE 
IN 90 DAYS OR 
OTHER PERIOD 



146 



CENTRAL OFFICE 
RECEIVES CLIENT'S 
PAYMENT FROM 
U\W FIRM 



132 



EXAMINE 
SITUATION AND 
CORRECT 
ERRORS 



® 



138 
__i 



SEND INVOICE 
TO CLIENT (BY 
LAW FIRM) AT 
END OF MONTH 
OR OTHER PERIOD 



140 




INVOICE DUE 
IN 30 DAYS OR 
OTHER PERIOD 


142 




LAW FIRM RECEIVES 
MONEY FROM 
CLIENT 


144 




LAW FIRM SENDS 

PAYMENT TO 
CENTRAL OFFICE 



FIG. 1B 



210- 



ENTRY OF FILE NUMBER AND/OR OTHER 
IDENTIFICATION INFO. AND REQUESTED 
AMOUNT INTO REMOTE WORKSTATION 



212- 



I 



WORKSTATION ISSUES AUTHORIZATION 
CODE FOR DEBIT OF REQUESTED 
AMOUNT FROM DEPOSIT ACCOUNT 



213-1 



214 



I 



TRANSMITTAL INCLUDING AUTHORIZATION 
CODE SENT TO EPO/PCT 
(DEPOSIT ACCOUNT AUTHORIZATION) 



EPO/PCT RECEIVES 
TRANSMITTAL AND DEBITS 
DEPOSIT ACCOUNT 



220 
S 



CENTRAL OFFICE 
DEPOSITS MONEY 
IN ACCOUNT OR 
OTHERWISE INSURE 
ADEQUATE FUNDS 
PRESENT 



226 
_S 




INFORMATION REGARDING 
AUTHORIZATION UPLOADEO 
TO CENTRAL OFFICE BY WS 



218- 



ELECTRONIC INVOICE GENERATED 
AND TRANSMITTED TO LAW FIRM 
ACCOUNTING SYSTEM; PAPER 
INVOICE ALSO GENERATED 
BY WORKSTATION 



CENTRAL OFFICE RECEIVES 
MONTHLY STATEMENT OF 
ACCOUNT DEBITS 
IDENTIFIED BY 
AUTHORIZATION CODE 




CENTRAL OFFICE RECONCILES 

MONTHLY STATEMENT WITH 
INFORMATION UPLOADED BY WS 



FIG. 2A 



© 
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RECONCILIATION 
OK? 



234 



YES 



CENTRAL OFFICE 
SENDS BILL TO 
LAW FIRM FOR 
MONEY LOANED 
TO CLIENTS 



236 



BILL DUE 
IN 90 DAYS OR 
OTHER PERIOD 



246 



CENTRAL OFFICE 
RECEIVES CLIENT'S 
PAYMENT FROM 
. LAW FIRM 



NO 



232 



EXAMINE 
SITUATION AND 
CORRECT 
ERRORS 



238 



SENO INVOICE 
TO CLIENT (BY 
LAW FIRM) AT 
END OF MONTH 
OR OTHER PERIOD 



240 




INVOICE DUE 
IN 30 DAYS OR 
OTHER PERIOD 


242 




LAW FIRM RECEIVES 
MONEY FROM 
CLIENT 


244 




LAW FIRM SENDS 

PAYMENT TO 
CENTRAL OFFICE 



FIG. 2B 
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ENTRY OF FILE NUMBER AND/OR OTHER 
310 J IDENTIFICATION INFO. AND AMOUNT FOR 
CHECK, INTO REMOTE WORKSTATION 
AT LAW FIRM 



311- 



TO STEP 
120 OR 220 



TO STEP 
144 OR 214 



312H 



313^ 



WORKSTATION E 
CONTACTS CENTS 
CONFIRMATION 


LECTRONICALLY 
M OFFICE FOR 
J/APPROVAL 






WORKSTATION ISSUES CHECK 
OR AUTHORIZATION CODE 






CODE OR CHECK SENT 
TO PATENT AGENCY 




TO STEP 
122 OR 222 



FIG. 3 
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410 



LAW FIRM 



418 

S 

ACCOUNTING/ 
BILUNG 
SYSTEM 



~422 



CHECK 
PRINTING/ 
AUTH. CODE 
SYSTEM 

— ? — 

416 



434 



420 



412 



PATENT 
AND 
TRADEMARK 

PAYMENT 
FEE SYSTEM 



432 _ 



426 



424 



PATENT 
AGENCY 



428 
_j 



414 



430 
L. 



ACCOUNT 



PATENT AGENCY 
OR FINANCIAL 
INSTITUTION 



FIG, 4 
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July 22. 1997 Payee: U.S. Patent & Trademark Office 

Fee Code: 101/201 Basic Filing Fee-Utility 
Client Number: 00997 
Matter Number: xxxx 

Note: This requires special attention. 



July 22, 1997 $ 2,000.0 

Two Thousand AND 0/1OO DOLLARS 
U.S. Patent & Trademark Office 



FIG. 18 


PTO Management Company Invoice 
Invoice Oate: July 22. 1997 


Item: 

Check Number: 1511 
From Account: 

58-67-9785 - PTFM Checks for U.S. PTO 




Request by: 

Brion Lorson on: 07/22/1997 12:53:16 
Client Number. 00997 Matter Number, xxxx 
Note: Ibis requires special attention. 




Check Amount: 
Fee: 


' $ 2.000.0 
$ 1 18.75 


Total Due By 09/20/1997: 


$ 2.118.75 


Discounted Total Due If Paid By 08/11/1997: 
Discounted Total Due If Paid By 08/11/1997: 


$ 2.029.69 
$ 2.059.38 


FIG. 19 



Deposit Account Authorization 


PTFM EPO Deposit Account 


Account Number XYZ234784 


Authorization Number: SIWK00021Q23 




Date Fee Code 


Check Amount 


July 22. 1997 sdhfsfd 


$ 300.0 


Payee: European Patent Office 




Requested by: Brian Larson 


on: 07/22/1997 12:44:18 


Client Number: 00999 




Matter Number sfgs 


Fee Assessed: $ 6.75 



FIG. 20 



PT0 Management Company Invoice 

Invoice Date: July 22, 1997 


Rem: 

Authorization Number: SLWK00021023 
From Account: 

XYZ234784 - PTFM EPO Deposit Account 
Request by: 

Brian Lorson on: 07/22/1997 12:53:16 
Client Number 00999 Matter Number xxxx 




Authorization Amount: 


$ 300.0 


Fee: 


$ 6.75 


Total Que By 08/21/1997: 


$ 306.75 





FIG. 21 
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Database: PTFM 



Structure for table: 
Number of data records: 
Date of last update: 
Code Page: 



Field 


Field Name 




Width 


1 


AC CODE 




8 


2 


AC__NAME 




30 


3 


AC_CLIENTNUM 




10 


4 


AC CLIENTNAM 




50 


5 


AC ACCOUNTNU 




20 


6 


AC ACCOUNTTY 




18 


7 


AC BALANCE 




12 


8 


AC NEXTCHECK 




10 


** Total 


** 




159 


Structure 


for table: 



Number of data records: 
Date of last update: 
Memo file block size: 
Code Page: 

Field Field Name 
Width 

1 AT_TYPE 

18 

2 AT_KEEPBALAN. . 

1 

3 AT_TRANSTYPE . . 

4 

4 AT_PAYEES 

4 

5 AT_CANEXCEED 

1 

6 AT_CHARGEFEE 

1 



C : \PMCSOURCE\ ACCOUNT . DBF 

9 

07/15/1997 
1252 



Type 




Index Collate 


Nulls 


Character 




Asc Machine 


No 


Character 




Asc Machine 


No 


Character 






No 


Character 






No 


Character 






No 


Character 






No 


Numeric 






No 


Numeric 






No 



C : \PMCSOURCE\ACCTTYPE . DBF 

9 

06/10/1997 
64 

1252 

Type 

Dec Index Collate Nulls 

Character 

No 

Logical 

No 

Memo 

No 

Memo 

No 

Logical 

No 

Logical 

No 



FIG. 24A 



7 


AT CHECKONLY 
1 


Logical 


No 


8 


AT AUTHOR I ZA . . 
1 


Logical 


No 


9 


AT USPTOCODE 
1 


Logical 


No 


10 


AT EPOCODE 
1 


Logical 


No 


11 


AT EXPORTTOP . . 
1 


Logical 


No 



** Total ** 



Structure for table: 
Number of data records: 
Date of last update: 
Code Page: 

Field Field Name 
Width 

1 CL__CLIENTNUM . 

10 

2 CL_NAME 

50 

3 CL_PLAN 

20 



C : \PMCSOURCE\CLIENT . DBF 



** Total ** 



81 



Structure for table: 
Number of data records: 
Date of last update: 
Memo file block size: 
Code Page: 

Field Field Name 
Width 

1 DE_CODE 

8 

2 DE_CL I ENTNUM . 

20 

3 DE_MATTERNUM. 

20 • 

4 DE_DATET I ME 

8 

5 DEJTRANSACTI . 

3 



06/20/1997 
1252 

Type 

Dec Index Collate 

Character 

Character 

Character 



Nulls 
No 
No 
No 



C : \PMCSOURCE\DETAIL . DBF 

69 

07/15/1997 
64 

1252 

Type 

Dec Index Collate 

Character 



Character 
Character 
DateTime 
Character 



Nulls 
No 
No 
No 
No 
No 



FIG, 24B 



6 DE_ 

7 DE_ 

8 DE_ 

9 DE_ 

10 DE_ 

11 DE_ 

12 DE_ 

13 DE_ 

14 DE_ 

15 DE_ 

16 DE_ 

17 DE_ 

18 DE_ 

19 DE_ 

20 DE_ 

21 DE_ 

22 DE_ 

23 DE_ 
** Total ** 



PAYEE 
" 50 

PTOCODE 
" 75 
AMOUNT 
10 

PLUSMINUS 
2 

WHO 
" 25 

LOCATION 
* 10 

CHECKNUMB. 
" 10 
NOTES 
4 

FEE1 
8 

DATEDUE1 
8 

FEE2 
8 

DATEDUE2 
8 

FEE3 
8 

DATEDUE3 
8 

STATUS 
17 

SELECTED 
1 

PRINTDATE . 
8 

EXPORTDAT . 
8 

328 



Character 

Character 

Numeric 

Numeric 

Character 

Character 

Numeric 

Memo 

Numeric 

Date 

Numeric 

Date 

Numeric 

Date 

Character 
Logical 
DateTime 
DateTime 



No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 



Structure for table: 
Number of data records: 
Date of last update: 
Code Page: 

Field ' Field Name 
Width 



C : \ PMCSOURCE \ PTOCODE . DBF 

149 

05/16/1997 
1252 

Type 

Dec Index Collate Nulls 



PIG. 24C 



1 

2 

** Total ** 



PT CODE 
75 

PT_USPTOCODE 
1 

77 



Structure for table: 
Number of data records: 
Date of last update : 
Code Page: 



Character 
Logical 



C : \PMCSOURCE\RATE . DBF 

48 

06/27/1997 
1252 



No 
No 



ild 


Field Name 




Type 






Width 


Dec 


Index Collate 


Nulls 


l 


RA PLAN 
20 




Character 


No 


2 


RA LOWERLIMI. 




Numeric 






8 


2 




No 


3 


RA UPPERLIMI. 




Numeric 






8 


2 




No 


4 


RA DAYS DUE 1 
3 




Numeric 


No 


5 


RA AMOUNT 1 




Numeric 






8 


2 




No 


6 


RA DAYSDUE2 
3 




Numeric 


No 


7 


RA AMOUNT 2 




Numeric 






8 


2 




No 


8 


RA DAYS DUE 3 
3 




Numeric 


No 


9 


RA AMOUNT 3 




Numeric 






8 


2 




No 


10 


RA NOT AL LOWE . . 
1 




Logical 


No 



** Total ** 



71 



Structure for table: 
Number of data records: 
Date of last update: 
Memo file block size: 
Code Page : 

Field Field Name 
Width 
1 SU_ITEM 
20 



C : \ PMCSOURCE\ SETUP . DBF 

10 

07/22/1997 
64 

1252 

Type 

Dec Index Collate Nulls 

Character 

No 



FIG- 24D 



2 SU_NUMBER Numeric 

10 2 No 

3 SU_DATA Memo 

4 No 

** Total ** 

35 



Structure for table: C:\PMCSOURCE\TRANTYPE.DBF 

Number of data records : 6 
Date of last update: 06/10/1997 

Code Page: 1252 



Field 


Field Name 


Type 






Width Dec 


Index Collate 


Nulls 


1 


TR TRANSACT I . . 
3 


Character 


No 


2 


TR DESCRIPTI. . 
20 


Character 


No 


3 


TR PLUSMINUS 
2 


Numeric 


No 


4 


TR CHKACCTVA . . 
1 


Logical 


No 


5 


TR AUTACCTVA. . 
1 


Logical 


No 


6 


TR CHKLIMITE . . 
1 


Logical 


No 


7 


TR AUTLIMITE . . 
1 


Logical 


No 


8 


TR CHARGEFEE 
1 


Logical 


No 


Total 


** 

31 







Structure for table: C:\PMCSOURCE\USER.DBF 
Number of data records: 1 
Date of last update: 05/02/1997 
Code Page: 1252 



Field 


Field Name 




Type 






Width 


Dec 


Index Collate 


Nulls 


1 


US ID 
20 




Character 


No 


2 


US LAST 
15 




Character 


No 


3 


US FIRST 
15 




Character 


No 


4 


US PASSWORD 
15 




Character 


No 



FIG. 24E 
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5 


US CHE C KB ALA 

1 


.LiL/y J. a _L 


No 


6 


US_VIEWREQUE. . 
1 


Logical 


No 


7 


US_CREATEREQ . . 
1 


Logical 


No 


8 


US_CANCELREQ . . 
1 


Logical 


No 


9 


US_MODIFYACC. . 
1 


Logical 


No 


10 


US_PRINTREPO . . 
1 


Logical 


No 


11 


US EXTRACTDA. . 


Logical 





1 NO 
** Total ** 

73 



Program File: MAIN.PRG 

_SCREEN. Width =633 
_SCREEN. Height =418 
_SCREEN . Icon = "opening . ico" 

SET CENTURY ON 

SET BELL OFF 

SET CONFIRM ON 

SET DELETED ON 

SET MULT I LOCKS ON 

SET PROCEDURE TO MAIN.PRG 

OPEN DATABASE PTFM 

PUBLIC frmMenu, gcLoginID, gcFullName, gcLocation, gcProgName 

USE Setup 

SET ORDER TO- Item 

IF SEEK ( " PROGNAME" ) 

gcProgName = TRIM (Setup. SU_Data) 

_SCREEN . Caption = gcProgName 

ELSE 

gcProgName = "Patent & Trademark Fee Management" 

ENDIF 

IF SEEK ( " LOGINID " ) 

gcLoginID = TRIM (Setup . SU_Data) 

ELSE 

gcLoginID = "Unknown" 



FIG. 24P 



END IF 



IF SEEK ( " FULLNAME " ) 

gcFullName = TRIM (Setup . SU_Dat a) 

ELSE 

gcFullName = "Unknown" 

END IF 

IF SEEK ("LOCATION") 

gcLocation = TRIM (Setup. SU_Dat a) 

ELSE 

gcLocation * "Unknown" 

END IF 

CLOSE TABLES ALL 

DO FORM Menu NAME f rmMenu 

READ EVENTS 

************************************* 
FUNCTION GetDueDate 

* Finds the Monday which is the specified number of weeks after 

* the date the request was made. If the request was made on a 

* Monday, do not count that Monday. 
LPARAMETERS ldDate, InNumMondays 

Local InMondayCnt 

InMondayCnt = 0 

DO WHILE InMondayCnt < InNumMondays 
ldDate = ldDate +1 
IF DOW (ldDate, 2) = 1 

InMondayCnt = InMondayCnt + 1 

ENDIF 

END DO 

RETURN ldDate 

************************************* 
FUNCTION TextDollar 

PARAMETERS nNumber 

LOCAL InDollars, InCents 

InDollars = INT (nNumber) 

InCents = (nNumber - InDollars) * 100 



FIG. 24G 



RETURN TextNumeric (lnDollars)+ "AND "+STR (InCents, 2) +"/100 
DOLLARS " 

************************************* 

FUNCTION TextNumeric 

PARAMETERS nNumber 

LOCAL lcString, InWorkNumber 

InWorkNumber = nNumber 
lcString = " " 

IF InWorkNumber >= 1000000 

lcString =* TextNumeric (InWorkNumber/ 10000 00) + "Million » 

InWorkNumber = InWorkNumber - 
(INTUnWorkNumber/lOOOOOO) *1000000) 
END IF 

IF InWorkNumber >= 1000 

lcString = lcString + TextNumeric (InWorkNumber/ 1000) + 
"Thousand 11 

InWorkNumber = InWorkNumber - (INT (InWorkNumber/ 1000) * 1000) 

ENDIF 
DO CASE 

CASE InWorkNumber >= 900 

lcString = lcString + "Nine Hundred " 

InWorkNumber = InWorkNumber - 900 
CASE InWorkNumber >= 800 

lcString « lcString + "Eight Hundred " 

InWorkNumber = InWorkNumber - 800 
CASE InWorkNumber >= 700 

lcString = lcString + "Seven Hundred 

InWorkNumber = InWorkNumber - 700 
CASE InWorkNumber >= 600 

lcString = lcString + "Six Hundred » 

InWorkNumber = InWorkNumber - 600 
CASE InWorkNumber >= 500 

lcString = lcString + "Five Hundred " 

InWorkNumber = InWorkNumber - 500 
CASE InWorkNumber >= 400 

lcString = lcString + "Four Hundred M 

InWorkNumber = InWorkNumber - 400 
CASE InWorkNumber >= 300 

lcString = lcString + "Three Hundred " 

InWorkNumber = InWorkNumber - 300 
CASE InWorkNumber >= 200 
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lcString * lcString + "Two Hundred 
InWorkNumber = InWorkNumber - 200 

CASE InWorkNumber >= 100 

lcString = lcString + "One Hundred 
InWorkNumber = InWorkNumber - 100 

ENDCASE 

DO CASE 

CASE InWorkNumber >= 90 

lcString = lcString + "Ninety " 
InWorkNumber = InWorkNumber - 90 

CASE InWorkNumber >= 80 

lcString ■ lcString + "Eighty n 
InWorkNumber = InWorkNumber - 80 

CASE InWorkNumber >= 70 

lcString « lcString + "Seventy " 
InWorkNumber = InWorkNumber - 70 

CASE InWorkNumber >= 60 

lcString = lcString + "Sixty n 
InWorkNumber = InWorkNumber - 60 

CASE InWorkNumber >= 50 

lcString = lcString + "Fifty " 
InWorkNumber = InWorkNumber - 50 

CASE InWorkNumber >= 40 

lcString = lcString + "Forty ■ 
InWorkNumber = InWorkNumber - 40 

CASE InWorkNumber >= 3 0 

lcString = lcString + "Thirty " 
InWorkNumber = InWorkNumber - 30 

CASE InWorkNumber >= 20 

lcString = lcString + "Twenty " 
InWorkNumber = InWorkNumber - 20 

CASE InWorkNumber >= 19 

lcString = lcString + "Nineteen " 
InWorkNumber = InWorkNumber - 19 

CASE InWorkNumber >= 18 

lcString = lcString + "Eighteen ■ 
InWorkNumber « InWorkNumber - 18 

CASE InWorkNumber >= 17 

lcString » lcString + "Seventeen * 
InWorkNumber = InWorkNumber - 17 

CASE InWorkNumber >= 16 

lcString = lcString + "Sixteen " 
InWorkNumber = InWorkNumber - 16 

CASE InWorkNumber >= 15 

lcString = lcString + "Fifteen " 
InWorkNumber = InWorkNumber - 15 
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CASE InWorkNumber >= 14 

lcString = lcString + "Fourteen " 
InWorkNumber = InWorkNumber - 14 

CASE InWorkNumber >= 13 

lcString « lcString + "Thirteen " 
InWorkNumber = InWorkNumber - 13 

CASE InWorkNumber >= 12 

lcString = lcString + "Twelve " 
InWorkNumber = InWorkNumber - 12 

CASE InWorkNumber >= 11 

lcString = lcString + "Eleven " 
InWorkNumber = InWorkNumber - 11 

CASE InWorkNumber >= 10 

lcString = lcString + "Ten n 
InWorkNumber = InWorkNumber - 10 

END CASE 

DO CASE 

CASE InWorkNumber >= 9 

lcString ■ lcString + "Nine " 
InWorkNumber = InWorkNumber - 9 

CASE InWorkNumber >= 8 

lcString ■ lcString + "Eight " 
InWorkNumber = InWorkNumber - 8 

CASE InWorkNumber >= 7 

lcString = lcString + "Seven " 
InWorkNumber = InWorkNumber - 7 

CASE InWorkNumber >= 6 

lcString = lcString + "Six " 
InWorkNumber » InWorkNumber - 6 

CASE InWorkNumber >= 5 

lcString = lcString + "Five " 
InWorkNumber = InWorkNumber - 5 

CASE InWorkNumber >= 4 

lcString = lcString + "Four » 
InWorkNumber = InWorkNumber - 4 

CASE InWorkNumber >= 3 

lcString = lcString + "Three " 
InWorkNumber = InWorkNumber - 3 

CASE InWorkNumber >= 2 

lcString = lcString + "Two " 
InWorkNumber = InWorkNumber - 2 

CASE InWorkNumber >= 1 

lcString = lcString + "One " 
InWorkNumber = InWorkNumber - 1 

ENDCASE 
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IF EMPTY (lcSt ring) 

IcString = "No » 

END IF 

RETURN IcString 



PIG. 24K 



